package com.atguigu.gulimall.order;

import io.seata.spring.annotation.GlobalTransactional;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

/**
 * 使用RabbitMQ
 * 1、引入amqp场景；RabbitAutoConfiguration 就会自动生效
 * 2、给容器中自动配置了
 *      RabbitTemplate 、 AmqpAdmin 、 CachingConnectionFactory 、 RabbitMessagingTemplate
 *      所有的属性都是在这里绑定spring.rabbitmq
 *          @ConfigurationProperties(prefix = "spring.rabbitmq")
 *          public class RabbitProperties
 * 3、给配置文件中配置 spring.rabbitmq 信息
 * 4、@EnableRabbit : 开启rabbit功能
 * 5、监听消息：使用@RabbitListener ， 必须要有@EnableRabbit支持
 *      @RabbitListener ： 可以标注在类或方法上 (用于标记监听哪些队列即可)
 *      @RabbitHandler : 标在方法上 （用于重载区分不同的消息）
 *
 *  本地事务失效问题
 *    同一个对象内事务方法互调默认失效，原因：绕过了代理对象,事务使用代理对象来控制的
 *    解决：使用代理对象来调用事务方法
 *      1）、引入aop-starter;spring-boot-starter-aop 引入了aspectj
 *      2）、@EnableAspectJAutoProxy(exposeProxy = true)；开启aspectj动态代理功能。以后所有的动态代理都是aspectj创建的（即使没有接口也可以创建动态代理）
 *              (exposeProxy = true) 对外暴露代理对象
 *      3）、本类互调用对象，本类方法互调这么做。
 *
 *   Seata控制分布式事务
 *      1、每一个微服务必须创建undo_log
 *      2、安装事务协调器：seata-server ：https://github.com/seata/seata/releases
 *      3、整合：
 *          1、导入依赖 spring-cloud-starter-alibaba-seata  根据导入的依赖包看io.seata:seata-all:1.3.0去下载对应版本的seata-server
 *          2、解压并启动seata-server：
 *                registry.conf:注册中心配置；修改registry type = nacos
 *                file.conf:
 *          3、所有想要用到分布式事务的微服务使用seata  DataSourceProxy代理自己的数据源
 *          4、每个微服务，都必须导入
 *                  file.conf     spring.cloud.alibaba.seata.tx-service-group=gulimall-order-fescar-service-group
 *                  registry.conf
 *          5、启动测试分布式事务
 *          6、给分布式大事务的入口标注@GlobalTransactional
 *          7、给每一个远程的小事务用@Transactional
 */
@EnableAspectJAutoProxy(exposeProxy = true)
@SpringBootApplication
@MapperScan("com.atguigu.gulimall.order.dao")
@EnableRabbit
@EnableDiscoveryClient
@EnableRedisHttpSession
@EnableFeignClients
public class GulimallOrderApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallOrderApplication.class, args);
    }

}
